home *** CD-ROM | disk | FTP | other *** search
/ Enter 2004 January / enter-2004-01.iso / files / maxima-5.9.0.exe / {app} / share / maxima / 5.9.0 / src / numerical / slatec / dbesj1.lisp < prev    next >
Encoding:
Text File  |  2003-02-09  |  3.2 KB  |  75 lines

  1. ;;; Compiled by f2cl version 2.0 beta 2002-05-06
  2. ;;; 
  3. ;;; Options: ((:prune-labels nil) (:auto-save t) (:relaxed-array-decls t)
  4. ;;;           (:coerce-assigns :as-needed) (:array-type ':simple-array)
  5. ;;;           (:array-slicing nil) (:declare-common nil)
  6. ;;;           (:float-format double-float))
  7.  
  8. (in-package "SLATEC")
  9.  
  10.  
  11. (let ((ntj1 0)
  12.       (xsml 0.0)
  13.       (xmin 0.0)
  14.       (bj1cs (make-array 19 :element-type 'double-float))
  15.       (first nil))
  16.   (declare (type f2cl-lib:logical first)
  17.            (type (simple-array double-float (19)) bj1cs)
  18.            (type double-float xmin xsml)
  19.            (type f2cl-lib:integer4 ntj1))
  20.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (1) ((1 19))) -0.11726141513332787)
  21.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (2) ((1 19))) -0.2536152183079064)
  22.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (3) ((1 19))) 0.050127080984469566)
  23.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (4) ((1 19))) -0.004631514809625082)
  24.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (5) ((1 19))) 2.4799622941591407e-4)
  25.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (6) ((1 19))) -8.678948686278827e-6)
  26.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (7) ((1 19))) 2.142939171437937e-7)
  27.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (8) ((1 19))) -3.93609307918318e-9)
  28.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (9) ((1 19))) 5.591182317946881e-11)
  29.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (10) ((1 19))) -6.327616404661393e-13)
  30.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (11) ((1 19))) 5.840991610857247e-15)
  31.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (12) ((1 19))) -4.4825338187012576e-17)
  32.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (13) ((1 19))) 2.905384492625025e-19)
  33.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (14) ((1 19))) -1.6117321978414414e-21)
  34.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (15) ((1 19))) 7.739478819392746e-24)
  35.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (16) ((1 19))) -3.248693782111998e-26)
  36.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (17) ((1 19))) 1.2022376772274104e-28)
  37.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (18) ((1 19))) -3.95201221265135e-31)
  38.   (f2cl-lib:fset (f2cl-lib:fref bj1cs (19) ((1 19))) 1.1616780822664534e-33)
  39.   (setq first f2cl-lib:%true%)
  40.   (defun dbesj1 (x)
  41.     (declare (type double-float x))
  42.     (prog ((ampl 0.0) (theta 0.0) (y 0.0) (dbesj1 0.0))
  43.       (declare (type double-float dbesj1 y theta ampl))
  44.       (cond
  45.        (first
  46.         (setf ntj1
  47.                 (initds bj1cs 19
  48.                  (* 0.1f0 (f2cl-lib:freal (f2cl-lib:d1mach 3)))))
  49.         (setf xsml (f2cl-lib:fsqrt (* 8.0 (f2cl-lib:d1mach 3))))
  50.         (setf xmin (* 2.0 (f2cl-lib:d1mach 1)))))
  51.       (setf first f2cl-lib:%false%)
  52.       (setf y (coerce (abs x) 'double-float))
  53.       (if (> y 4.0) (go label20))
  54.       (setf dbesj1 0.0)
  55.       (if (= y 0.0) (go end_label))
  56.       (if (<= y xmin)
  57.           (xermsg "SLATEC" "DBESJ1" "ABS(X) SO SMALL J1 UNDERFLOWS" 1 1))
  58.       (if (> y xmin) (setf dbesj1 (* 0.5 x)))
  59.       (if (> y xsml)
  60.           (setf dbesj1
  61.                   (* x (+ 0.25 (dcsevl (- (* 0.125 y y) 1.0) bj1cs ntj1)))))
  62.       (go end_label)
  63.      label20
  64.       (multiple-value-bind
  65.           (var-0 var-1 var-2)
  66.           (d9b1mp y ampl theta)
  67.         (declare (ignore var-0))
  68.         (setf ampl var-1)
  69.         (setf theta var-2))
  70.       (setf dbesj1 (* (f2cl-lib:sign ampl x) (cos theta)))
  71.       (go end_label)
  72.      end_label
  73.       (return (values dbesj1 nil)))))
  74.  
  75.